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Foreword 



rd , 



This Technical Specification has been produced by the 3 Generation Partnership Project (3GPP). 

The contents of the present document are subject to continuing work within the TSG and may change following formal 
TSG approval. Should the TSG modify the contents of the present document, it will be re-released by the TSG with an 
identifying change of release date and an increase in version number as follows: 

Version x.y.z 

where: 

X the first digit: 

1 presented to TSG for information; 

2 presented to TSG for approval; 

3 or greater indicates TSG approved document under change control. 

y the second digit is incremented for all changes of substance, i.e. technical enhancements, corrections, 
updates, etc. 

z the third digit is incremented when editorial only changes have been incorporated in the document. 
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1 Scope 

This 3GPP Technical Specification (TS) specifies: 

1. The interactions between the HSS (Home Subscriber Server) and the SIP AS (AppHcation Server) and 
between the HSS and the OSA SCS (Service CapabiUty Server). This interface is referred to as the Sh 
reference point. 

2. The interactions between the SIP AS and the SLF (Subscription Locator Function) and between the OSA SCS 
and the SLF. This interface is referred to as the Dh reference point. 

The IP Multimedia (IM) Core Network Subsystem stage 2 is specified in 3GPP TS 23.228 [1] and the signalling flows 
for the IP multimedia call control based on SIP and SDP are specified in 3GPP TS 24.228 [2]. 

The IP Multimedia (IM) Session Handling with the IP Multimedia (IM) call model is specified in 3GPP TS 23.218 [4]. 

This document addresses the signalling flows and message contents for the protocol at the Sh and Dh interface. 

This document also addresses how the functionality of Ph interface is accomplished. 

The Presence Service Stage 2 description (architecture and functional solution) is specified in 3GPP TS 23.141 [18]. 



References 



[ 1 ] 3GPP TS 23 .228 : "IP Multimedia (IM) Subsystem - Stage 2" . 

[2] 3GPP TS 24.228: "Signalling flows for the IP multimedia call control based on SIP and SDP". 

[3] 3GPPTS 23.002 "Network architecture". 

[4] 3GPP TS 23.218: "IP Multimedia (IM) Session HandHng; IP Multimedia (IM) call model" 

[5] 3GPP TS 29.329: "Sh Interface based on Diameter - Protocol details" 

[6] 3GPP TS 29.228: "IP multimedia (IM) Subsystem Cx Interface; Signalling flows and Message 
Elements". 

[7] 3GPP TS 29.229: "Cx and Dx Interfaces based on the Diameter protocol ; Protocol details" 

[8] IETF RFC 3588 "Diameter Base Protocol" 

[9] ITU-T recommendation Q.763: "Signalling System No. 7 - ISDN User Part formats and codes" 

[10] 3GPP TS 23.018: "Basic Call Handling; Technical realization" 

[11] 3GPP TS 23.003: "Numbering, Addressing and Identification" 

[12] 3GPP TS 23.032: "Universal Geographical Area Description (GAD)" 

[13] 3GPP TS 29.002: "Mobile Application Part (MAP) specification" 

[14] 3GPP TS 23.078: "Customised Applications for Mobile network Enhanced Logic (CAMEL) Phase 
3 - Stage 2" 

[15] RFC 2045: "Multipurpose Internet Mail Extensions (MIME) Part One: Format of Internet Message 
Bodies" 

[16] RFC 3261: "SIP: Session Initiation Protocol" 

[17] RFC 2806: "URLs for Telephone Calls" 

[18] 3GPP TS 23.141: "Presence Service; Architecture and Functional Description" 
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[19] TS 23.012: "Location Management Procedures" 

3 Definitions, symbols and abbreviations 

3.1 Definitions 

For the purposes of the present document, the following terms and definitions apply. 

IP Multimedia session: IP Multimedia session and IP Multimedia call are treated as equivalent in this specification. 

Transparent data: Data that is understood syntactically but not semantically by the HSS. It is data that an AS may 
store in the HSS to support its service logic. One example is data that an AS stores in the HSS, using it as a repository. 

Non-transparent data: Data that is understood both syntactically and semantically by the HSS. 

AS (Application Server): a term used to denote either of a SIP Application Server or an OS A Service Capability 
Server. 

3.2 Abbreviations 

For the purposes of the present document, the following abbreviations apply: 



AS 


Application Server 


CSCF 


Call Session Control Function 


C 


Conditional 


HSS 


Home Subscriber Server 


IE 


Information Element 


IP 


Internet Protocol 


IM 


IP Multimedia 


IMS 


IP Multimedia Subsystem 


M 


Mandatory 





Optional 


SIP 


Session Initiation Protocol 


SLF 


Subscription Locator Function 


S-CSCF 


Serving CSCF 



4 IVIain Concept 

This document presents the Sh interface related functional requirements of the communicating entities. 
It gives a functional classification of the procedures and describes the procedures and message parameters. 
Error handling flows, protocol version identification, etc. procedures are also included. 

5 General Architecture 

This clause further specifies the architectural assumptions associated with the Sh reference point, building on 3GPP 
TS 23.228 [1, 3GPP TS 23.218 [4] and also the Ph reference point building upon 3GPP TS 23.141 [18]. 

5.1 Functional requirements of network entities 
5.1 .1 Functional Requirements of tine Application Server 

The Application Server may communicate with the HSS over the Sh interface. 
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For functionality of the Application Server refer to 3GPP TS 23.002 [3], 3GPP TS 23.228 [1] and 3GPP TS 23.218 [4]. 

5.1 .2 Functional requirements of HSS 

The HSS may communicate with the Application Server over the Sh interface and with the Presence Network Agent 
over the Ph interface. The functionality of the Ph interface shall be the same as the functionality of the Sh interface. 

For functionality of the HSS refer to 3GPP TS 23.002 [3], 3GPP TS 23.228 [1] and 3GPP TS 23.218 [4]. 

5.1 .3 Functional Requirements of the Presence Network Agent 

The Presence Network Agent may communicate with the HSS over the Ph interface. In this case, all references to an 
Application Server in this specification apply also to a Presence Network Agent. 

5.2 Functional classification of Sh interface procedures 

Operations on the Sh interface are classified in functional groups: 

1 . Data handling procedures 

The download of data from the HSS to an AS. 
The update of data in the HSS. 

2. Subscription/notification procedures 

An AS can subscribe to receive notifications from the HSS of changes in data. 

The HSS can notify an AS of changes in data for which the AS previously had subscribed. 



Procedure Descriptions 



In the tables that describe the Information Elements transported by each command, each Information Element is marked 
as (M) Mandatory, (C) Conditional or (O) Optional. 

A mandatory Information Element (marked as (M) in the table) shall always be present in the command. If this 
Information Element is absent, an application error occurs at the receiver and an answer message shall be sent 
back to the originator of the request with the Result-Code set to DIAMETER_MISSING_AVP. This message 
shall also include a Failed-AVP AVP containing the missing Information Element i.e. the corresponding 
Diameter AVP defined by the AVP Code and the other fields set as expected for this Information Element. 

A conditional Information Element (marked as (C) in the table) shall be present in the command if certain 
conditions are fulfilled. 

If the receiver detects that those conditions are fulfilled and the Information Element is absent, an application 
error occurs and an answer message shall be sent back to the originator of the request with the Result-Code 
set to DIAMETER_MISSING_AVP. This message shall also include a Failed-AVP AVP containing the 
missing Information Element i.e. the corresponding Diameter AVP defined by the AVP Code and the other 
fields set as expected for this Information Element. 

If those conditions are not fulfilled, the Information Element shall be absent. If however this Information 
Element appears in the message, it shall not cause an application error and it may be ignored by the receiver 
if this is not explicitly defined as an error case. Otherwise, an application error occurs at the receiver and an 
answer message with the Result-Code set to DIAMETER_AVP_NOT_ALLOWED shall be sent back to the 
originator of the request. A Failed-AVP AVP containing a copy of the corresponding Diameter AVP shall be 
included in this message. 

An optional Information Element (marked as (O) in the table) may be present or absent in the command, at the 
discretion of the application at the sending entity. Absence or presence of this Information Element shall not 
cause an application error and may be ignored by the receiver. 
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6.1 User data handling procedures 
6.1.1 Data read (Sh-Pull) 

This procedure is used between the AS and the HSS. The procedure is invoked by the AS and is used: 

To read transparent and/or non-transparent data for a specified user from the HSS. 

This procedure is mapped to the commands User-Data-Request/ Answer in the Diameter application specified in 3GPP 
TS 29.329 [5]. Tables 6.1.1.1 and 6.1.1.2 detail the involved information elements. 
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Table 6.1.1.1 :Sh-Pull 



Information 
element name 


IVIapping to 
Diameter AVP 


Cat. 


Description 


User Identity 
(See 7.1) 


User-Identity 


M 


IIVIS Public User Identity or IVISISDN of the user for whom the data is 

required. 

See section 7.1 for the content of this AVP. 


Requested 

data 
(See 7.3) 


Data- 
Reference 


M 


This information element indicates the reference to the requested 
information. The set of valid reference values are defined in 7.6. 


Requested 
Identity set 
(See 7.11) 


Identity-Set 





If Data-Reference indicates that IIVIS Public Identities is the requested data 
set to be downloaded, this information element should be included. 

When this information element takes the value IIVIPLICITJDENTITIES, the 
HSS shall provide all non-barred IIVIS Public Identities that are belong to 
the same implicit registration set as the IMS Public Identity included in the 
message in the User-Identity AVP. The MSISDN user identity is not 
applicable for this value. 

When this information element takes the value 
REGISTEREDJDENTITIES, the HSS shall provide all non-barred IMS 
Public Identities whose state is registered, belonging to all Private Identities 
that the IMS Public Identity or MSISDN in the User-Identity AVP is 
associated with. 

When this information element takes the value ALLJDENTITIES, the HSS 
shall provide all non-barred IMS Public Identities, belonging to all Private 
Identities that the IMS Public Identity or MSISDN in the User-Identity AVP is 
associated with. 

If Data-Reference indicates that IMS Public Identities is the requested data 
set to be downloaded and this information element is not included, the HSS 
shall download the set of IMS Public Identities that would be downloaded if 
the value of this information element had been ALL IDENTITIES. 


Requested 

domain 

(See 7.2) 


Requested- 
Domain 


C 


This information element indicates the domains to which the operation is 
applicable. Check table 7.6.1 to see when it is applicable. 


Current 
Location 
(See 7.8) 


Current- 
Location 


C 


This information element indicates whether an active location retrieval has 
to be initiated or not. It shall be present if Location Information is requested. 
If this information element takes the value InitiateActiveLocationRetrieval 
(1) the HSS shall indicate to the MSC/VLR and/or SGSN the need to 
initiate an active location retrieval. 
Check table 7.6.1 to see when it is applicable. 


Service 
Indication 
(See 7. 4) 


Service- 
Indication 


C 


IE that identifies, together with the IMS Public User Identity included in the 
User-Identity AVP and Data-Reference, the set of service related 
transparent data that is being requested. 
Check table 7.6.1 to see when it is applicable. 


Application 

Server Identity 

(See 7.9) 


Origin-Host 


M 


IE that identifies the AS originator of the request and that is used to check 
the AS permission list. 


Application 
Server Name 


Server-Name 


C 


IE that is used, together with the IMS Public User Identity included in the 
User-Identity AVP and Data-Reference, as key to identify the filter criteria. 
Check table 7.6.1 to see when it is applicable. 
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Table 6.1.1.2: Sh-PullResp 



Information 
element name 


IVIapping to 
Diameter AVP 


Cat. 


Description 


Result 
(See 7.5) 


Result-Code / 

ExperimentaL 

Result 


M 


Result of the request. 

Result-Code AVP shall be used for errors defined In the Diameter Base 
Protocol. 

Experimental-Result AVP shall be used for Sh errors. This is a grouped 
AVP which contains the 3GPP Vendor ID in the Vendor-Id AVP, and the 
error code in the Experimental-Result-Code AVP. 


Data 
(See 7.6) 


User-Data 





Requested data. 



6.1.1.1 



Detailed behaviour 



The conditions for the inclusion of Requested-Domain as an additional key to the requested data are described in table 
7.6.1. If repository data is requested, Service-Indication shall be present in the request. If initial filter criteria are 
requested, the Server-Name AVP shall contain the SIP URL of the AS that initiates the request; requests for initial filter 
criteria are limited to those initial filter criteria which are relevant to the requesting AS. 

Upon reception of the Sh-Pull request, the HSS shall, in the following order: 

1. In the AS permission list (see section 6.2) check that the requested user data is allowed to be read (Sh-Pull) by 
this AS by checking the combination of the identity of the AS sending the request (identified by the Origin-Host 
AVP) and the supplied Data-Reference. 

If the data referenced in the request is not allowed to be read, Experimental-Result Code shall be set to 
DIAMETER_ERROR_USER_DATA_CANNOT_BE_READ in the Sh-Pull Response. 

2. Check that the user for whom data is asked exists in HSS. If not, Experimental-Result-Code shall be set to 
DIAMETER_ERROR_USER_UNKNOWN in the Sh-Pull Response. 

3. Check whether or not the data that is requested to be downloaded by the AS is currently being updated by 
another entity. If there is an update of the data in progress, the HSS may delay the Sh-Pull-Resp message until 
the update has been completed and shall include in the Sh-Pull-Resp message the updated data requested. The 
HSS shall ensure that the data returned is not corrupted by this conflict. 

If there is an error in any of the above steps then the HSS shall stop processing and shall return the error code specified 
in the respective step (see 3GPP TS 29.329 [5] and 3GPP TS 29.229 [7] for an explanation of the error codes). 

If the HSS cannot fulfil the received request for reasons not stated in the above steps, e.g. due to database error, it shall 
stop processing the request and set Result-Code to DIAMETER_UNABLE_TO_COMPLY. 

Otherwise, the requested operation shall take place and the HSS shall return the Result-Code AVP set to 
DIAMETER_SUCCESS and the requested data identified by User-Identity and Data-Reference in the Sh-Pull Response 

message. 



6.1 .2 Data Update (Sh-Update) 



This procedure is used between the AS and the HSS. The procedure is invoked by the AS and is used: 

To allow the AS to update the transparent (repository) data stored at the HSS for a specified user. 

This procedure is mapped to the commands Profile-Update-Request/ Answer in the Diameter application specified in 
3GPP TS 29.329 [5]. Tables 6.1.2.1 and 6.1.2.2 detail the involved information elements. 
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Table 6.1.2.1 :Sh-Update 



Information 
element name 


IVIapping to 
Diameter AVP 


Cat. 


Description 


User Identity 
(See 7.1) 


User-Identity 


M 


IMS Public User Identity of the user which data is updated. 
See section 7.1 for the content of this AVP. 


Requested 

data 
(See 7.3) 


Data- 
Reference 


M 


This information element includes the reference to the data on which 
updates are required (possible values of the Data Reference are defined in 
Table 7.6.1). 


Data 
(See 7.6) 


User-Data 


M 


Updated data. 


Application 

Server Identity 

(See 7.9) 


Origin-Host 


M 


IE that identifies the AS originator of the request and that is used to check 
the AS permission list. 



Table 6.1.2.2: Sh-Update Resp 



Information 
element name 


IVIapping to 
Diameter AVP 


Cat. 


Description 


Result 
(See 7.5) 


Result-Code / 
Experimental- 
Result 


M 


Result of the update of data in the HSS. 

Result-Code AVP shall be used for errors defined In the Diameter Base 
Protocol. 

Experimental-Result AVP shall be used for Sh errors. This Is a grouped 
AVP which contains the 3GPP Vendor ID in the Vendor-Id AVP, and the 
error code in the Experimental-Result-Code AVP. 



6.1.2.1 



Detailed behaviour 



Within the Sh-Update Request, the keys to determine the updated data are part of the information element Data (See 
7.6). When data in the repository is updated (i.e. added, modified or removed) Service-Indication and Sequence- 
Number are also sent as part of the information element Data. 

Newly added transparent data shall be associated with a Sequence Number of in the Sh-Update Request. Sequence 
Number value is reserved exclusively for indication of newly added transparent data. 

Modified and removed transparent data shall be associated within the Sh-Update Request with a Sequence Number of 
n-nl where n is the original Sequence Number associated with the transparent data before modification or removal. If n 
equals 65535, then the next modification or deletion of that transparent data shall be associated with a Sequence 
Number of 1 . 

Upon reception of the Sh-Update request, the HSS shall, in the following order: 

1. In the AS permission list (see section 6.2) check that the user data that is requested to be updated (Sh-Update) by 
this AS, is allowed to be updated by checking the combination of the identity of the AS sending the request 
(identified by the Origin-Host AVP) and the supplied Data-Reference. 

If the data is not allowed to be updated, Experimental-Result Code shall be set to 
DIAMETER_ERROR_USER_DATA_CANNOT_BE_MODIFIED in the Sh-Update Response. 

2. Check that the user for whom the data is asked to be updated exists in the HSS. If not, Experimental-Result-Code 
shall be set to DIAMETER_ERROR_USER_UNKNOWN in the Sh-Update Response. 

3. Check whether or not the data that is requested to be updated by the AS, as identified by the Service-Indication, 
is currently being updated by another entity. If there is an update of the data in progress, Experimental-Result 
Code shall be set to DIAMETER_PRIOR_UPDATE_IN_PROGRESS in the Sh-Update Response. 

4. Check whether or not there is any repository data stored at the HSS already for the specified Service-Indication 
and the associated user. 

- If repository data identified by the Service-Indication is stored at the HSS for the specified user, check the 
following premises: 
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1. Sequence_Number_in_Sh_Update is not equal to 

2. (Sequence_Number_in_Sh_Update - 1) is equal to (Sequence_Number_In_HSS modulo 65535) 

If either of the above premises is false then Experimental-Result-Code shall be set to 
DIAMETER_ERROR_TRANSPARENT_DATA_OUT_OF_SYNC in the Sh-Update Response. 

If both of the above premises are true, then check whether or not Service Data is received within the Sh- 
Update Req. 

If Service Data is included in the Sh-Update Req, check whether or not the size of the data is greater 
than that which the HSS is prepared to accept. 

If there is more data than the HSS is prepared to accept then Experimental-Result-Code shall be 
set to DIAMETER_ERROR_TOO_MUCH_DATA and the new data shall be discarded. 

If the HSS is prepared to accept the data, then the repository data stored at the HSS shall be 
updated with the repository data sent in the Sh-Update Req and the Sequence Number associated 
with that repository data shall be updated with that sent in the Sh-Update Req. This triggers the 
sending of Sh-Notif messages to any other ASs that are subscribed to Notifications for updates to 
the service data for that user (see 6.1.4). 

If Service Data is not received, the data stored in the repository at the HSS shall be removed, and as a 
consequence the Service Indication and the Sequence Number associated with the removed data shall 
also be removed. This triggers the sending of Sh-Notif messages to any other ASs that are subscribed 
to Notifications for updates to the service data for that user (see 6.1.4). After sending Sh-Notif 
messages, the subscriptions to Notifications for the removed Repository Data shall be deleted. 

If repository data identified by the Service-Indication is not stored for the user i.e. the Sh-Update Req 
intends to create a new repository data, check whether or not the Sequence Number in the Sh-Update Req is 
0. 

If the sequence number is not set to 0, Experimental-Result Code shall be set to 
DIAMETER_ERROR_TRANSPARENT_DATA_OUT_OF_SYNC 

If the sequence number is set to check whether Service Data is included within the Sh-Update Req. 

If Service Data is not included in the Sh-Update Req, then Experimental-Result-Code shall be set to 
DIAMETER_ERROR_OPERATION_NOT_ALLOWED and the operation shall be ignored by the 
HSS. 

If Service Data is included in the Sh-Update Req, check whether or not the size of the data is greater 
than that which the HSS is prepared to accept. If there is more data than the HSS is prepared to accept 
then Experimental-Result-Code shall be set to DIAMETER_ERROR_TOO_MUCH_DATA and the 
new data shall be discarded. 

If the HSS is prepared to accept the data included in the Sh-Update Req, then the data shall be stored 
inwithin the data repository in the HSS. 

If there is an error in any of the above steps then the HSS shall stop processing and shall return the error code specified 
in the respective step (see 3GPP TS 29.329 [5] and 3GPP TS 29.229 [7] for an explanation of the error codes). 

If the HSS cannot fulfil the received request for reasons not stated in the above steps, e.g. due to database error, it shall 
stop processing the request and set Result-Code to DIAMETER_UNABLE_TO_COMPLY. 

Otherwise, the requested operation shall take place and the HSS shall return the Result-Code AVP set to 
DI AMETER_S UCCES S . 

NOTE: When an AS receives DIAMETER_ERROR_TRANSPARENT_DATA_OUT_OF_SYNC the AS may 
attempt to resolve the inconsitency between the version of the repository data that it holds and that stored 
at the HSS. It may execute a Sh-Pull to retrieve the current version of the data from the HSS or it tmay 
wait to receive a subsequent Sh-Notif message from the HSS for the affected repository data. 
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6.1 .3 Subscription to notifications (SIn-Subs-Notif) 

This procedure is used between the AS and the HSS. The procedure is invoked by the AS and is used: 

To subscribe to Notifications for when particular transparent and/or non-transparent data for a specified user is 
updated, from the HSS. 

This procedure is mapped to the commands Subscribe-Notifications-Request/ Answer in the Diameter application 
specified in 3GPP TS 29.329 [5]. Tables 6.1.3.1 and 6.1.3.2 detail the information elements involved. 

Table 6.1 .3.1 : Sh-Subs-Notif 



Information 

element 

name 


Mapping to 

Diameter 

AVP 


Cat. 


Description 


User Identity 
(See 7.1) 


User-Identity 


M 


IMS public identity of the user for wfiom notifications of data changes are 
requested. See section 7.1 for the content of this AVP. 


Requested 

data 
(See 7.3) 


Data- 
Reference 


M 


This information element includes the reference to the data on which 
notifications of change are required (valid reference values are defined in 7. 
6). 


Subscription 

request type 

(See 7.7) 


Subs-Req- 
Type 


M 


This information element indicates the action requested on subscription to 
notifications. 


Service 
Indication 
(See 7.4) 


Service- 
Indication 


C 


IE that identifies, together with the IMS Public User Identity and Data- 
Reference, the set of service related transparent data for which 
notifications of changes are requested. 

This element shall be present when the Data-Reference value is 
Repository Data (0). 


Application 

Server Identity 

(See 7.9) 


Origin-Host 


M 


IE that identifies the AS originator of the request and that is used to check 
the AS permission list. 


Application 
Server Name 


Server-Name 


C 


IE that is used, together with the IMS Public user Identity and Data- 
Reference, as key to identify the filter criteria. 
This element shall be present when the Data-Reference value is 
lnitialFilterCriteria(13). 



Table 6.1.3.2: Sh-Subs-Notif Resp 



Information 

element 

name 


Mapping to 

Diameter 

AVP 


Cat. 


Description 


Data request 

result 

(See 7.5) 


Result-Code / 
Experimental- 
Result 


M 


Result of the request. 

Result-Code AVP shall be used for errors defined in the Diameter Base 
Protocol. 

Experimental-Result AVP shall be used for Sh errors. This is a grouped 
AVP which contains the 3GPP Vendor ID in the Vendor-Id AVP, and the 
error code in the Experimental-Result-Code AVP. 



6.1.3.1 



Detailed behaviour 



The HSS shall take note of the subscription request on the data identified by IMS Public User Identity and Data- 
Reference. If notifications on changes of repository data are requested, Service-Indication shall be present in the 
request. If notifications on changes of filter criteria are requested, the Server-Name AVP shall be used as key to the 
filter criteria. The Server-Name AVP shall contain the SIP URL of the AS sending the request. 

Upon reception of the Sh-Subs-Notif request, the HSS shall, in the following order (if there is an error in any of the 
following steps the HSS shall stop processing and return the corresponding error code, see 3GPP TS 29.329 [5] and 
3GPP TS 29.229 [7]): 
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1. In the AS permission list (see section 6.2) the HSS shall check that the AS is allowed to subscribe to 
notifications (Sh-Subs-Notif) for the requested user data by checking the combination of the identity of the AS 
sending the request (identified by the Origin-Host AVP) and the supplied Data-Reference. 

If this AS does not have Sh-Subs-Notif permission for the data referenced, Experimental-Result Code shall 
be set to DIAMETER_ERROR_USER_DATA_CANNOT_BE_NOTIFIED in the Sh-Subs-Notif Response. 

2. Check that the user for whom notifications are asked exists in HSS. If not, Experimental-Result Code shall be set 
to DIAMETER_ERROR_USER_UNKNOWN in the Sh-Subs-Notif Response. 

If the HSS cannot fulfil the received request for reasons not stated in the above steps, e.g. due to database error, it shall 
stop processing the request and set Result-Code to DIAMETER_UNABLE_TO_COMPLY. 

6.1.4 Notifications (Sh-Notif) 

This procedure is used between the HSS and the AS. The procedure is invoked by the HSS and is used: 

To inform the AS of changes in transparent and/or non-transparent data to which the AS has previously 
subscribed to receive Notifications for, using Sh-Subs-Notif (see 6.1.3). 

This procedure is mapped to the commands Push-Notification-Request/ Answer in the Diameter application specified in 
3GPP TS 29.329 [5]. Tables 6.1.4.1 and 6.1.4.2 detail the involved information elements. 

Table 6.1.4.1 :Sh-Notif 



Information 
element name 


IVIapping to 
Diameter AVP 


Cat. 


Description 


User Identity 
(See 7.1) 


User-Identity 


M 


IMS Public User Identity of the user which data has changed. 
See section 7.1 for the content of this AVP. 


Requested 

Data 
(See 7.6) 


User-Data 


M 


Changed data. 



Table 6.1.4.2: Sh-NotIf Resp 



Information 
element name 


IVIapping to 
Diameter AVP 


Cat. 


Description 


Data request 

result 

(See 7.5) 


Result-Code / 
Experimental- 
Result 


M 


Result of the request. 

Result-Code AVP shall be used for errors defined in the Diameter Base 
Protocol. 

Experimental-Result AVP shall be used for Sh errors. This is a grouped 
AVP which contains the 3GPP Vendor ID in the Vendor-Id AVP, and the 
error code in the Experimental-Result-Code AVP. 



6.1.4.1 



Detailed behaviour 



The keys to the updated data are part of the information element User-Data (See Annex C). When data repository is 
updated Service-Indication is also part of the information element User-Data. 

Since authentication pending is a transient state of normally very short duration, notification of an IMS user's state 
change, to and from the authentication pending state shall not be sent to Application Servers, when the previous state 
before authentication pending and next state after authentication pending are the same. If the states are different before 
the authentication pending state is entered and after the authentication pending state is left then notification is sent to the 
AS of this new state. 



6.5 User identity to HSS resolution 



The User identity to HSS resolution mechanism enables the AS to find the address of the HSS that holds the subscriber 
data for a given public user identity when multiple and separately addressable HSSs have been deployed by the network 
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operator. The resolution mechanism is not required in networks that utilise a single HSS or when an AS is configured to 
use pre-defmed HSS. 

The resolution mechanism described in 3GPP TS 23.228 [8] is based on the Subscription Locator Function (SLF). The 
AS accesses the subscription locator via the Dh interface. The Dh interface is always used in conjunction with the Sh 
interface. The Dh interface is based on Diameter. Its functionality is implemented by means of the routing mechanism 
provided by an enhanced Diameter redirect agent, which is able to extract the public user identity from the received 
requests. 

To get the HSS address the AS sends to the SLF the Sh requests aimed for the HSS. On receipt of the HSS address from 
the SLF, the AS shall send the Sh requests to the HSS. The AS may store the HSS address and use it in further requests 
associated to the same public user identity. 

In networks where the use of the user identity to HSS resolution mechanism is required and the AS is not configured to 
use predefined HSS, each AS shall be configured with the address/name of the SLF implementing this resolution 
mechanism. 



6.2 AS permissions list 



In table 7.6. 1, the contents of the Data-AVP are described. Some of the individual elements carried within Data-AVP 
may be requested by the AS from the HSS using the Sh-Pull command (see section 6. LI) or may be updated at the HSS 
by the AS using the Sh-Update command (see section 6.L2). The AS may also request that the HSS notifies the AS of 
changes to specific elements within the Data-AVP using the Sh-Subs-Notif command (see section 6.1.3). The HSS will 
only allow these operations to take place if the element of the Data-AVP is permitted to be included in the specific 
command requested by the AS, as indicated in table 7.6.1. 

To manage whether an AS may request each element of Data-AVP with a specific command, the HSS shall maintain a 
list of AS permissions (the "AS Permissions List"). AS permissions are identified by AS identity and Data Reference 
with the possible permissions associated with each Data Reference being Sh-Pull, Sh-Update, Sh-Subs-Notif or any 
combination of these permissions (see table 7.6.1 for details of which permissions are allowed for each Data 
Reference). The permissions apply to all users served by the HSS, they are not user specific. When an AS requests Sh- 
Pull, Sh-Update or Sh-Subs-Notif the HSS shall check permissions and return an error result if the AS does not have the 
required permission. 



7 Information element contents 

7.1 User Identity 

This information element contains a user identity according to the conditions described in table 7.1.1. 

Table 7.1.1 : User Identity content 



Information 
element name 


IVIapping to 
Diameter AVP 


Cat. 


Description 


IMS Public 
User Identity 
(See 7.1.1) 


Public-Identity 


C 


IMS Public User Identity of the user for whom the data is required. If the 
MSISDN is not included in the User-Identity AVP, the Public-Identity AVP 
shall be included in Sh messages only for allowed Data References as 
described in Table 7.6.1 . 


MSISDN 
(See 7.1.2) 


MSISDN 


C 


MSISDN of the user for whom the data is required. If the Public-Identity 
AVP is not included in the User-Identity AVP, the MSISDN AVP shall be 
included in the Sh-Pull message only for allowed Data References as 
described in Table 7.6.1 . 



7.1 .1 IMS Public User Identity 



This information element contains an IMS public user identity (either SIP-URI or TEL-URL). 
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7.1.2 MSISDN 

This information element contains a Basic MSISDN (see 3GPP TS 23.012 [19]). 

7.2 Requested Domain 

This information element details the access domains for which certain data (e.g. user state, location information) are 
requested. See 3GPP TS 29.329 [5] for the Hst of possible values. 

7.3 Requested Data 

Reference to the data that an AS is requesting from the HSS. 
Reference to the data which, an AS wants to be notified of, when changed. 
Reference to data for which subscription to notification of change is rejected. 
See chapter 7.6. 

7.4 Service Indication 

Identifier of one set of service related transparent data, which is stored in an HSS in an operator network. It shall be 
unique within an operator network. Per user and value of Service Indication the HSS may allocate memory space to 
implement a data repository to store transparent data. 

7.5 Result 

This information element contains the result code of the operation. See 3GPP TS 29.329 [5] for the list of possible 
values. 

7.6 Data 

This information element contains an XML document conformant to the XML schema defined in Annex D. 

Annex C specifies the UML logical model of the data downloaded via the Sh interface. 

Table 7.6.1 defines the data reference values and tags, access key and recommended AS permissions (as described in 
section 6.2) for the the operation(s) on data accessible via the Sh interface, i.e. the listed operation(s) in the Operations 
column are the only ones allowed to be used with this Data Ref value. It is a matter of operator policy to further restrict 
the AS permission rights defined in table 7.6.1. 
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Table 7.6.1 : Data accessible via Sh interface 



Data 
Ref. 


XIVIL tag 


Defined in 


Access key 


Operations 





RepositoryData 


7.6.1 


IMS Public User Identity + 
Data-Reference + 
Service-Indication 


Sh-Pull, Sh-Update, Sh-Subs- 
Notif 


10 


IMSPublicldentity 


7.6.2 


IMS Public User Identity 

or MSISDN + Data- 
Reference + Identity-Set 


Sh-Pull 


11 


IMSUserState 


7.6.3 


IMS Public User Identity -i- 
Data- Reference 


Sh-Pull, Sh-Subs-Notif 


12 


S-CSCFName 


7.6.4 


Sh-Pull, Sh-Subs-Notif 


13 


InitialFilterCriteria 


7.6.5 


IMS Public User Identity -i- 
Data- Reference -i- Server- 
Name 


Sh-Pull, Sh-Subs-Notif 


14 


Locationlnformation 


7.6.6 


MSISDN -1- Data- 

Reference+ Requested- 

Domain 


Sh-Pull 


15 


UserState 


7.6.7 


16 


Charging information 


7.6.8 


IMS Public User Identity 
or MSISDN + Data- 
Reference 


Sh-Pull 


17 


MSISDN 


7.6.9 


Sh-Pull 



7.6.1 Repository Data 

This information element contains transparent data. A data repository may be shared by more than one AS 
implementing the same service. 

7.6.2 IMSPublicldentity 

This information element contains an IMS Public User Identity that would be either: 

associated with the Private Identity of the subscriber for whom the IMS User Public Identity is included in the 
request or 

associated with the MSISDN present in the request. 

Multiple instances of this information element may be included in the message. 

7.6.3 IMS User State 

This information element contains the IMS User State of the public identifier referenced. Its possible values are: 

- REGISTERED, 

- NOT_REGISTERED, 

- AUTHENTICATION_PENDING, 

- REGISTERED_UNREG_SERVICES. 

If the Public User Identity is shared between multiple Private User Identities, HSS shall indicate the most registered 
state of the shared Public User Identity to an AS. The most registered state of a shared Public User Identity is defined 
as follows: 

If the shared Public User Identity is registered with any of the Private User Identities, the most registered state of 
the shared Public User Identity is REGISTERED. 

If the shared Public User Identity is not currently registered with any of the Private User Identities, but it is in 
state REGISTERED_UNREG_SERVICES, then the most registered state of the shared Public User Identity is 
REGISTERED UNREG SERVICES. 
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If the shared Public User Identity is not currently registered with any of the Private User Identities, and it is not 
in state REGISTERED_UNREG_SER VICES, but it is in the process of being authenticated with any of the 
Private User Identities, then the most registered state of the shared Public User Identity is 
AUTHENTICATION_PENDING. 

If the shared Public User Identity is not currently registered with any of the Private User Identities, and it is not 
in state REGISTERED_UNREG_SER VICES, and it is not in the process of being authenticated with any of the 
Private User Identities, then the most registered state of the shared Public User Identity is NOT_REGISTERED. 

7.6.4 S-CSCF Name 

This information element contains the name of the S-CSCF where a multimedia public identity is registered. 

7.6.5 Initial Filter Criteria 

This information element contains the triggering information for a service. 

For a more detailed description, refer to 3GPP TS 23.218 [4] and 3GPP TS 29.228 [6]. 

7.6.6 Location Information 

This information elementcontains the location of the served subscriber in the MSC/VLR if the requested domain is CS, 
or the location of the served subscriber in the SGSN if the requested domain is PS. If the HSS has to communicate with 
the MSC/VLR and/or SGSN to retrieve location information, it shall make use of the service MAP-PRO VIDE- 
SUBSCRIBER-INFO. 

For both Location Information for CS and Location Information for GPRS, the considerations described in 3GPP TS 
23.078 [14] apply. 

7.6.6.1 Location information for CS 

This information elementconsists of the following subordinate information elements: 

Location number: defined in ITU-T Recommendation Q.763 [9]. Considerations described in 3GPP TS 23.018 
apply[10]. 

- Service area ID: defined in 3GPP TS 23.003 [11]. 

- Global Cell ID: defined in 3GPP TS 23.003 [11]. 

- Location area ID: defined in 3GPP TS 23.003 [11]. 

- Geographical Information: defined in 3GPP TS 23.032 [12]. Considerations described in 3GPP TS 23.018 [10] 
and 3GPP TS 29.002 [13] apply. 

Geodetic Information: defined in ITU-T Recommendation Q.763 [9]. Considerations described in 3GPP TS 
23.018 [10] and 3GPP TS 29.002 [13] apply. 

- VLR Number: defined in 3GPP TS 23 .003 [11]. 

- MSC Number: defined in 3GPP TS 23.003 [11]. 

- Age of location information: defined in 3GPP TS 23.018 [10]. 

Current Location Retrieved: shall be present when location information was obtained after a successful paging 
procedure for Active Location Retrieval. 

7.6.6.2 Location information for GPRS 

This information element consists of the following subordinate information elements: 

- Service area ID: defined in 3GPP TS 23.003 [11]. 
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- Global Cell ID: defined in 3GPP TS 23.003 [11]. 

- Location area ID: defined in 3GPP TS 23.003 [11]. 

- Geographical Information: defined in 3GPP TS 23.032 [12]. Considerations described in 3GPP TS 23.018 [10] 
and 3GPP TS 29.002 [13] apply. 

Geodetic Information: defined in ITU-T Recommendation Q.763 [9]. Considerations described in 3GPP TS 
23.018 [10] and 3GPP TS 29.002 [13] apply. 

- SGSN Number: defined in 3GPP TS 23.003 [11]. 

- Routing Area ID: defined in 3GPP TS 23.003 [11]. 

Current Location Retrieved: shall be present when location information was obtained after a successful paging 
procedure for Active Location Retrieval. 

7.6.7 User state 

This information element indicates the state of the user in the domain indicated by the Requested-Domain (see 7.2), 
with the values specified in 3GPP TS 23.078 [14] for Subscriber State and PS Domain Subscriber State. The HSS shall 
make use of the operation MAP-PROVIDE-SUBSCRIBER-INFO towards the MSC/VLR and/or the SGSN to obtain 
this information. 

7.6.8 Charging information 

This information element contains the addresses of the charging functions (primary event charging function name, 
secondary event charging function name, primary charging collection function name, secondary charging collection 
function name). When a clash occurs between the charging function address(es) received over the ISC interface and 
those received over the Sh interface, the address(es) received over the ISC interface should take precedence. 

NOTE: The use of the Sh interface to retrieve charging function addresses is not intended as a general-purpose 

alternative to receiving charging function addresses from the ISC interfaces. Rather, it is meant to address 
a special case where the AS needs to interact with the charging system before initiating a request to a user 
when the AS has not received the third party REGISTER for that user. 

7.6.9 MSISDN 

This information element contains a Basic MSISDN (see 3GPP TS 23.012 [19]) that is associated with the User Identity 
present in the request. All valid instances of this information element shall be included in the message. 



7.7 Subscription request type 



This information element indicates the action requested for subscription to notifications. See 3GPP TS 29.329 [5] for 
the list of valid values. 

7.8 Current Location 

This information element indicates whether an active location retrieval has to be initiated or not when an AS requested 
location information. See 3GPP TS 29.329 [5] for the list of possible values. 



7.9 Application Server Identity 



This information element contains the identity of the Application Server. It is used for the AS permission check (see 
6.2). 
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7.10 Application Server Name 



This information element indicates application server"s SIP URL See 3GPP TS 29.229 [7] for the detailed definition of 
the AVP. 



7.11 Requested Identity Set 



This information element indicates the set of IMS Public Identities that the AS wishes to download. See 3GPP TS 
29.329 [5] for the detailed definition of the AVP. 



8 Protocol version identification 

See 3GPPTS 29.329 [5]. 



9 Operational Aspects 

See 3GPPTS 29.329 [5]. 
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Annex A (normative): Mapping of Sh operations and 
terminology to Diameter 

A.1 Introduction 

This appendix gives mappings from Sh to Diameter protocol elements. Diameter protocol elements are defined in 3GPP 
TS 29.329 [5]. 

A.2 Sh message to Diameter command mapping 

The following table defines the mapping between stage 2 operations and Diameter commands: 
Table A.2.1 : Sh message to Diameter command mapping 



Sh message 


Source 


Destination 


Command-Name 


Abbreviation 


Sh-Pull 


AS 


HSS 


User-Data-Request 


UDR 


Sh-Pull Resp 


HSS 


AS 


User-Data-Answer 


UDA 


Sh-Update 


AS 


HSS 


Profile-Update-Request 


PUR 


Sh-Update Resp 


HSS 


AS 


Profile-Update-Answer 


PUA 


Sh-Subs-Notif 


AS 


HSS 


Subscribe-Notifications-Request 


SNR 


Sh-Subs-Notif Resp 


HSS 


AS 


Subscribe-Notifications-Answer 


SNA 


Sh-Notif 


HSS 


AS 


Push-Notification-Request 


PNR 


Sh-Notif Resp 


AS 


HSS 


Pusli-Notification-Answer 


PNA 



A.3 Void 
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Annex B (informative): 
Message flow 

B.1 Message flows 

The following message flows give examples regarding which Diameter messages shall be sent in scenarios described in 

3GPPTS 23.218 [4]. 



B.1.1 Data Update, Registration, Notification Subscription. 

Home Network 



s-csc 



3. REGISTER 



5. 200 OK 



User Profile Downloading 



HSS 



7. 200 OK 



AS 



1 . Sh-Update 



2. Sh-Update Reag 



6. REGISTER 
(Third Party) 



8. Sh-Pull 



9. Sh-Pull Res 
10. Sh-Subs Noti^ 



11.Sh-Subs_Notif Re sp 



At some point, the HSS sends updates to the AS (that previously subscribed) 



12. Sh-Notif 



13. Sh-Notif Resp 



At some point, the AS decides to update certain data in the HSS 



14. Sh-Update 



15. Sh-Update Rei;p 



Figure B.1.1: Data Update, Registration, Notification Subscription 

1. A user subscribes to a new service. The operator provisions the service in an AS. The AS stores some service 
data for a user in the HSS, Sh-Update (user identity, updated data) e.g. repository data. 

2. HSS confirms the data is updated 

3. Some time later, user registers with the network 
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4. S-CSCF downloads the data from the HSS (during the procedure S-CSCF Registration Notification on Cx 
interface). Fiher criteria specify that the AS wants to be notified that the end user is registered. 

5. 200 OK 

6. S-CSCF sends third party registration message to the application server to notify that user is registered. 

7. 200 OK 

8. The AS downloads data needed for providing service from HSS, by means of Sh-PuU (user identity, requested 
data, and service information). 

9. HSS sends data to AS 

10. The AS subscribes to notifications from the HSS of changes in data, by means of Sh-Subs-Notif (user identity, 
requested data, and/or service information). 

11. The HSS confirms the subscription request. 

12. At some moment, user data is updated in the HSS. As the AS subscribed to notifications (step 10), the HSS 
sends to the AS the requested updates, by means of Sh-Notif (user identity, updated data). 

13. The AS acknowledges the notification. 

14. At some moment, the AS decides to update user"s service data e.g. repository data in the HSS, by means of Cx- 
Update (user identity, updated data). 

15. The HSS confirms the service data is updated. 
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Annex C (informative): UIVIL model of the data downloaded 
over Sh i/f 

The purpose of this UML model is to define in an abstract level the structure of the data downloaded over the Sh 
interface and describe the purpose of the different information classes included in it. 



C.1 General description 



The following picture gives an outline of the UML model of the user profile, which is exchanged between the HSS and 
an AS: 



Sh-Data 



0...1 

Publicldentifiers 



0...1 
Sh-IMS-Data 



0..1 
CSUserState 



State: enumerated 



0...1 



RepositoryData 



Servicelndication 

SequenceNumber 

ServiceData 



0...1 



PSLocationlnformation 



GlobalCellld 

ServiceAreald 

LocationAreald 

RoutingAreald 

Geographicallnformation 

Geodeticlnformation 

AgeOfLocationlnformation 

CurrentLocationRetrieved 

SGSNNumber 



0...1 



CSLocationlnformation 



GlobalCellld 

ServiceAreald 

LocationAreald 

LocationNumber 

Geographicallnformation 

Geodeticlnformation 

AgeOfLocationlnformation 

CurrentLocationRetrieved 

VLRNumber 

MSCNumber 



0..1 
PSUserState 



State: enumerated 



Figure C.I. 1: Sh-Data 

Each instance of the Sh-Data class contains or 1 instance of the class Publicldentifiers, or 1 instance of the class 
Repository, or 1 instance of the class Sh-IMS-Data, or 1 instance of the class CSUserState, or 1 instance of the 
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class PSUserState and/or or 1 instance of the class CSLocationlnformation or or 1 instance of the class 
PSLocationlnformation. 

Class RepositoryData contains repository data (transparent data) for a given service. It has attributes Servicelndication, 
SequenceNumber and ServiceData. 

Class CSUserState contains the state of a user in the CS domain. Its only attribute, State, is an enumeration whose 
possible values are defined in chapter 7.6.7. 

Class PSUserState contains the state of a user in the PS domain. Its only attribute. State, is an enumeration whose 
possible values are defined in chapter 7.6.7. 

NOTE: the fact that attribute State is an enumeration is a difference from what can be carried in the MAP protocol. 

Class CSLocationlnformation has the attributes Location Number, Service Area ID, GlobalCellld, LocationAreald, 
Geographicallnformation, Geodeticlnformation, VLR Number, MSC Number, AgeOfLocationlnformation and 
CurrentLocationRetrieved. They are defined in 7.6. 

Class PSLocationlnformation has the attributes ServiceAreald, GlobalCellld, LocationArealD, RoutingArealD, 
Geographicallnformation, Geodeticlnformation, SGSN Number, AgeOfLocationlnformation and 
CurrentLocationRetrieved. They are defined in 7.6. 

C.2 Publicldentifiers 

The following picture details the UML model of the class Publicldentifiers: 



Publicldentifiers 







\ 


) 








0..n 






0..n 


IMSPublicldentity 




MSISDN 


Identity: SIP URL 
or TEL URL 









Figure C.2.1 : The UML model of the class Publicldentifiers 

Class Publicldentifiers contains to n user public identities which may be either of class IMSPublicldentity or of class 
MSISDN. The identifiers are of format SIP URL, TEL URL or MSISDN. 



C.3 Sh-IMS-Data 

The following picture details the UML model of the class Sh-IMS-Data. 
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0..1 



S-CSCFName 



ServerName: SIP_URL 



Sh-IMS-Data 



0..n 



InitialFilterCriteria 



FilterCriteria: 
tInitialFilterCriteria 





0..1 






0..1 


IMSUserState 




Charging Information 


IMSState: enumerated 


Charging Information : 
tCharginglnformation 







Figure C.3.1 : Sh-IMS-Data 

Each instance of the class Sh-IMS-Data contains or 1 instance of the class S-CSCFName, to n instances of the class 
InitialFilterCriteria, or 1 instance of the class IMSUserState, and/or or 1 instance of the class Charginglnformation. 

Class S-CSCFName contains the SIP URL of the S-CSCF where the multimedia public identity that the AS included in 
the request is registered. 

Class InitialFilterCriteria is defined in 3GPP TS 29.228 [6] and contains the initial filter criteria of the multimedia 
public identity that the AS included in the request. 

Class IMSUserState contains the registration state of the identity given by the attribute of class Sh-IMS-Data. See 
chapter 7.6 for possible values. 

Class Charging Information contains the online and offline charging function addresses. See chapter 7.6 for possible 
values. 
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Annex D (normative): 

XML schema for the Sh interface user profile 

The file ShDataType.xsd, attached to this specification, contains the XML schema for the user profile that is sent over 
the Sh interface. The user profile XML schema defines the data types types that are used in the user profile XML. The 
data that is allowed to be sent in the user profile may vary depending on the features supported by the Diameter end 
points, see 3GPP TS 29.229 [5]. The user profile XML schema file is intended to be used by an XML parser. The 
version of the Sh application sending the user profile XML shall be the same as the version of the sent user profile 
XML and thus it implies the version of the user profile XML schema to be used to validate it. 

Tables D.l and D.2 describe the data types and the dependencies among them that configure the user profile XML 
schema. 
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Table D.1 : XML schema for the Sh user profile interface: simple data types 



Data type 


Tag 


Base type 


Comments 


tPriority 


Priority 


integer 


>=0 


tGroupID 


Group 


integer 


>=0 


tRegistrationlype 


Registrationlype 


enumerated 


Possible values: 

(INITIAL_REGISTRATION) 

1 (RE-REGISTRATION) 

2 (DE-REGISTRATION) 


tDefaultHandling 


DefaultHandling 


enumerated 


Possible values: 

(SESSION_GONTINUED) 

1 (SESSION_TERMINATED) 


tDirectionOfRequest 


SessionCase 


enumerated 


Possible values: 

(ORIGINATING_SESSION) 

1 TERMINATING_SESSION 

2 (TERMINATING_UNREGISTERED) 


tIMSUserState 


IMSUserState 


Enumerated 


Possible values: 

(NOT_REGISTERED) 

1 (REGISTERED) 

2 (REGISTERED_UNREG_SERVICES) 

3 (AUTHENTICATION_PENDING) 


tCSUserState 


GSUserState 


Enumerated 


Possible values (as defined in 3GPP TS 23.078 
[14]): 

(CAMELBusy) 

1 (NetworkDeterminedNotReachable) 

2 (Assumedldle) 

3 (NotProvidedfromVLR) 


tPSUserState 


PSUserState 


Enumerated 


Possible values (as defined in 3GPP TS 23.078 
[14]): 

(Detached) 

1 (AttachedNotReachableForPaging) 

2 (AttachedReachableForPaging) 
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3 (ConnectedNotReaclnableForPaging) 








4 (ConnectedReaclnableForPaging) 








5 (NotProvidedFromSGSN) 


tLocationNumber 


LocationNumber 


string 


Syntax described in ITU-T Q.763 [9] (Base64 
encoded according to RFC 2045 [15]). 

Lengint >=4 and <=1 6 (multiples of 4). 


tCellGloballd 


GellGloballd 


string 


Syntax described in 3GPP TS 29.002 [13] 
(Base64 encoded according to RFC 2045 [15]). 

Length = 12. 


tServiceAreald 


ServiceAreald 


string 


Syntax described in 3GPP TS 29.002 [13] 
(Base64 encoded according to RFC 2045 [15]). 

Length = 12. 


tLocationAreald 


LocationAreald 


string 


Syntax described in 3GPP TS 29.002 [1 3] 
(Base64 encoded according to RFC 2045 [15]). 

Length = 8. 


tRoutingAreald 


RoutingAreald 


string 


Syntax described in 3GPP TS 29.002 [13] 
(Base64 encoded according to RFC 2045 [15]). 

Length = 8. 


tGeographicallnform 
ation 


Geographicallnform 
ation 


string 


Syntax described in 3GPP TS 29.002 (base 64 
encoded according to RFC 2045). 

Length = 12. 


tGeodeticlnformation 


Geodeticlnformatio 
n 


string 


Syntax described in 3GPP TS 29.002 [13] 
(Base64 encoded according to RFC 2045 [15]). 

Length = 16. 


tAgeOfLocationlnfor 
mation 


AgeOf Location Infor 
mation 


integer 


>=0, <=32767 


tAddressString 


AddressString 


string 


Syntax described in 3GPP TS 29.002 [13] 
(Base64 encoded according to RFC 2045 [15]). 

Length >= 4 and <=28 (multiples of 4). 


tMSISDN 


MSISDN 


string 


Syntax described in 3GPP TS 23.003 [11]. 


tSIP_URL 


Publicldentity 


anyURI 


Syntax described in RFC 3261 [16] 


tTEL_URL 


Publicldentity 


anyURI 


Syntax described in RFC 2806 [17] 


tDiameterURI 


DiameterURI 


string 


Syntax of a Diameter URI as described in IETF 
RFC 3588 [8] 


tIMSPublicldentity 


IMSPublicldentity 


(union) 


Union of tSIP_URL and tTEL_URL 
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tServicelnfo 


Servicelnfo 


string 




tString 


RequestURI, 

Method, Header, 

Content, Line 


string 




tBool 


ConditionTypeCNF, 
ConditionNegated 


boolean 


Possible values: 

(false) 

1 (true) 


tSequenceNumber 


SequenceNumber 


integer 


>=0, <=65535 
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Table D.2: XML schema for the Sh user profile interface: complex data types 



Data type 


Tag 


Compound of 


Tag 


Type 


Cardinality 


tSh-Data 


Sh-Data 


Publicldentifiers 


tPublicldentity 


Oto1 


RepositoryData 


tlransparentData 


Oto1 


Sh-IMS-Data 


tSlnlMSData 


Oto1 








CSLocationlnformati 
on 


tCSLocationlnformation 


Oto1 


PSLocationlnformati 
on 


tPSLocationlnformation 


Oto1 


CSUserState 


tCSUserState 


Oto1 


PSUserState 


tPSUserState 


Oto1 


tlransparentData 


RepositoryData 


Servicelndication 


string 


1 


SequenceNumber 


tSequenceNumber 


1 


ServiceData 


tServiceData 


Oto1 


tServiceData 


any 


any 


any 


1 


tShlMSData 


Sh-IMS-Data 


SCSCFName 


tSIP_URL 


Oto1 


InitialFilterCriteria 


tInitialFilterCriteria 


to n 


IMSUserState 


tIMSUserState 


Oto1 


CInarginglnformation 


tClnarginglnformation 


Oto1 


tCSLocationlnformati 
on 


CSLocationlnformat 
ion 


LocationNumber 


tLocationNumber 


Oto1 


CellGloballd 


tCellGloballd 


Oto1 


ServiceAreald 


tServiceAreald 


Oto1 


LocationAreald 


tLocationAreald 


Oto1 


Geograplnicallnforma 
tion 


tOeograplnicallnformation 


Oto1 
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Geodeticlnformation 


tGeodeticlnformation 


Oto1 


VLRNumber 


tISDNAddress 


Oto1 


MSCNumber 


tISDNAddress 


Oto1 


CurrentLocationRetri 
eved 


tBool 


Oto1 


AgeOf Location Inform 
ation 


tAgeOfLocationlnformatio 
n 


Oto1 


tPSLocationlnformati 
on 


PSLocationlnformat 
ion 


CellGloballd 


tCellGloballd 


Oto1 


ServiceAreald 


tServiceAreald 


Oto1 


LocationAreald 


tLocationAreald 


Oto1 


RoutingAreald 


tRoutingAreald 


Oto1 


Geographicallnforma 
tion 


tGeographicallnformation 


Oto1 


Geodeticlnformation 


tGeodeticlnformation 


Oto1 


SGSNNumber 


tISDNAddress 


Oto1 


CurrentLocationRetri 
eved 


tBool 


Oto1 


AgeOf Location Inform 
ation 


tAgeOfLocationlnformatio 
n 


Oto1 


tPublicldentity 


Publicldentifiers 


IMSPublicldentity 


tIMSPublicldentity 


Oto n 


MSISDN 


tMSISDN 


to n 


tInitialFilterCriteria 


InitialFilterCriteria 


Priority 


tPriority 


1 


TriggerPoint 


tTrigger 


Oto1 


ApplicationServer 


tApplicationServer 


1 


tTrigger 


TriggerPoint 


ConditionTypeCNF 


tBool 


1 
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SPT 


tSePoTri 


Oto n 


tSePoTri 


SPT 


ConditionNegated 


tBool 


Oto1 


Group 


tGroupID 


1 ton 


o 

CD 
O 
O 

sz 
O 


RequestURI 


tString 


1 


Method 


tString 


1 


SIPHeader 


tHeader 


1 


SessionCase 


tDirectionOfRequest 


1 


Session Descri 
ption 


tSessionDescription 


1 


RegistrationType 


tRegistrationType 


(0 to 2) 


tHeader 


SIPHeader 


Header 


tString 


1 


Content 


tString 


Oto1 


tSessionDescription 


Session Description 


Line 


tString 


1 


Content 


tString 


Oto1 


tApplicationServer 


ApplicationServer 


ServerName 


tSIP_URL 


1 


DefaultHandling 


tDefaultHandling 


Oto1 


Servicelnfo 


tServicelnfo 


Oto1 


tCharginglnformation 


Charginglnformatio 
n 


PrimaryEventChargin 
gFunctionName 


tDiameterURI 


Oto1 


SecondaryEventChar 
gingPunctionName 


tDiameterURI 


Oto1 


PrimaryCharging 

CollectionFunctionNa 

me 


tDiameterURI 


1 


SecondaryCharging 

CollectionFunctionNa 

me 


tDiameterURI 


Oto1 


NOTE: 'n' shall be interpreted as non-bounded. 
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Annex E: 
(void) 
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